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ENHANCED VIDEO PROGRAMMING SYSTEM AND 
METHOD PROVIDING A DISTRIBUTED COMMUNITY NETWORK 

The present invention relates to a method and apparatus for routing 
5 application layer packets of information in a network. 

Computers have the capability to provide massive amounts of educational 
and entertainment Information by way of the Internet. Currently, on-line systems 
offer a variety of different services to users, including news feeds, electronic 

1 0 databases (either searchable by user directly on the on-line system, or 

downloadable to the user's own computer), private message services, electronic 
newsletters, real time games for play by several users at the same time, and job 
placement services, to name a few. However, currently most on-line 
communications occur merely through text. This is in contrast to the audio/visual 

1 5 presentation of the alternative electronic medium, television. However, it is 
expected that as multi-media's incessant growth continues, audio/visual 
programs will proliferate and text will become less and less dominant in the on- 
line environment. 

20 Even though these programs will be introduced, the Internet will remain 

essentially user unfriendly due to its very massiveness, organization, and 
randomness. Simply stated, there is no order or direction in the Internet. 
Specific pieces of information can be hard to find, and it is even harder to put that 
piece of information into a meaningful context. 

25 

Television, on the other hand, has been criticized for being a passive 
medium. Whilst interactive television systems have increased the level of user 
interaction, and thus, provided greater learning and entertainment opportunities, 
vast information resources such as databases are inaccessible from such a 
30 medium. 

The present invention seeks to close the gap between video programming 
and the vast information resources of the Internet. 

35 According to a first aspect of the present invention there is provided a 

method for routing application layer packets of information in a network 
comprising: 
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receiving a packet which includes an indication of hierarchical routing 
information from a network service; and 

routing the packet to targets in a network based upon the hierarchical 
5 routing information. 

A method of an embodiment of the invention enables dynamic 
reconfiguration of a network for transmitting content, such as that located using 
URLs. The network, referred to as a distributed community network, preferably 
10 includes hubs which may logically reside on any machine and control the routing 
of packets containing content by using hubs to assist in routing packets, the 
burden of routing control at corresponding server is decreased, enhancing the 
reliability and efficiency of the network in transmitting content and permitting 
access to content. 

15 

The present invention also extends to a method for routing application 
layer packets of information in a network, comprising: 

receiving a packet containing identification of a network sen/ice and 
content; 

20 routing the packet to the network service; 

receiving from the network service the packet including hierarchical 
routing information; and 

routing the packet to targets based upon the hierarchical routing 
information. 

25 

According to a further aspect of the present invention there is provided 
apparatus for routing application layer packets of information in a network, 
comprising: 

receiving means for receiving a packet including an indication of 
30 hierarchical routing information from a network service; 

determination means for determining targets in a network for receiving the 
packet based upon the hierarchical routing information; and 

transmission means for transmitting the packet to the targets based upon 
the determining. 

35 



The invention also extends to apparatus for routing application layer 
packets of information in a network comprising: 
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first receiving means for receiving a packet containing identification of a 
network service and content; 

first routing means for routing the packet to the network sen/ice; 

second receiving means for receiving from the network sen/ice the packet 
5 with hierarchical routing information; and 

second routing means for routing the packet to targets based upon the 
hierarchical routing information. 

Embodiments of the present invention will hereinafter be described, by 
10 way of example, with reference to the accompanying drawings, in which; 

Figure 1 is a diagram showing the receipt and decoding of video signals 
at a subscriber location using a method of the invention; 

Figure 2 is a diagram showing an alternative embodiment to achieve the 
integration of Internet information with video content; 
1 5 Figure 3 is a flow diagram of the basic software of the invention; 

Figure 4 is a diagram showing an embodiment in which URLs are directly 
transmitted to a user; 

Figure 5 shows an embodiment of a system comprising a digital cable 

box; 

20 Figure 6 shows an embodiment of a system including a digital T.V.; 

Figure 7 shows an example of a user interface; 
Figure 8 shows an example of a display providing a user interface; 
Figure 9 is a diagram showing an embodiment of a system having 
distributed communication servers; 
25 Figure 10A shows an example of a physical network configuration for a 

distributed community network; 

Figure 10B shows an example of a physical network configuration for a 
particular application of a distributed community network; 

Figure 1 1 A shows an exemplary logical structure for a distributed 
30 community network; 

Figure 1 1 B shows an example of a physical network configuration for a 
distributed community network illustrating an alternative source for a video signal; 

Figure 12A illustrates an example of a content push packet flow in a 
distributed community network; 
35 Figure 12B shows an exemplary push/pull packet; 

Figure 13 illustrates chat packet flow in a distributed community network; 
Figure 14A shows an implementation of a distributed community network 
as a small eSchool; 
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Figure 14B shows an implementation of a distributed community network 

as a targe eSchool; 

Figure 14C illustrates an implementation of a distributed community 
network as a simple network providing video and other content; and 
5 Figure 14D shows a distributed community network as a complex network 

providing video and other content. 

Figure 1 illustrates an embodiment of a computer based system for 
receiving a video program along with embedded uniform resource locators 

10 (URLs) which direct a user's computer 16 to address locations, or web sites, on 
the Internet 20 to retrieve related web pages. The web pages correspond to the 
video presentation. The particular video programming can be delivered in 
analog, digital or digitally compressed formats (e.g. MPEG2) via any 
transmission means, including satellite, cable, wire, television broadcast or sent 

15 via the web. 

The video programming is preferably created at a centralized location, for 
example, as content creation 4 indicated in Figure 1, for distribution to 
subscribers. Program creation may be accomplished by any appropriate means. 

20 After a video program is created, uniform resource locators (URLs) are 
embedded. In one embodiment, the URLs are embedded into the vertical 
blanking interval of the video programming by a URL encoder 8, as shown in 
Figure 1 . In this embodiment, the URLs are encoded onto eight fields of line 21 
of the VBI. Line 21 is the line associated with close captioning, among other 

25 things. However, the URLs may additionally and/or alternatively be embedded in 
other fields of the VBI, in the horizontal portion of the video, as part of the audio 
channel, in any subcarrier to the video, or if the video is digital, in one of the data 
fields. 



30 Although Figure 1 shows the video with the URLs broadcast over the 

same transmission line, the URLs may be sent down independently of the video 
program on a data channel. In this embodiment, the URLs may be forwarded to 
the remote sites either prior to initiation or during the program. Preferably, the 
URLs have associated time stamps which indicate to the subscriber stations 

35 when, during the video program, to display the particular web pages addressed 
by the URLs. Alternatively, the user can select when to call the particular web 
pages for display with the video program. 
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The particular information in line 21 is not part of the visual part of the 
program, and thus, is not perceptible to the human eye, thereby making it ideal to 
send data information to the users. Whilst the bandwidth capacity of line 21 is 
limited, as a system as described transmits only the URLs, and not full web 
5 pages, there is more than enough capacity. Furthermore, no additional hardware 
is necessary at the computer 16 to receive the video and retrieve the web pages. 

Once the video program is created, it may be transmitted to user sites 
over any transmission means, including broadcast, cable, satellite, or Internet, 
10 and may reside on video servers. Furthermore, the video program, with or 

without embedded URLs, may be encoded onto storage means such as a video 
tape, for example of VHS or Beta format, or an optical disc such as CD or DVD, 
or any other medium. 

15 Preferably, each receiver station comprises any Intel x86 machine 

(preferably a 486 processor, pentium processor, etc), an Apple Computer, UNIX 
or any other type of standard computer workstation. The local computer 16 is 
preferably connected to either a cable and/or broadcast television or to a local 
VCR or other video source. At each subscriber site, the local personal computer 

20 16 preferably receives the cable transmission by cable connection on the back of 
the personal computer 16. The video/audio program may be processed for 
display on the computer screen using a PC card capable of displaying video 
signals on a computer monitor in an appropriate TV format such as PAL or 
NTSC. One example of a PC card is a WinTV card. In addition to the cable 

25 connection, there is the Internet 20 connection created concurrently with the 
cable connection. 



The Internet 20 connection may be via high-speed line, RF, conventional 
modem or by way of two-way cable carrying the video programming. The local 
30 PC 16 has Internet access via, for example, an ASCII software mechanism. In 
an embodiment, at each subscriber site, an associated local URL decoder 12 
extracts the URLs, preferably embedded in the vertical blanking interval, with the 
use of a suitable VBI decoder device. The URL decoder 12 may be either a 
stand-alone unit or a card which is implemented into the personal computer 16 

35 

In the embodiment shown in Figure 2, the uniform resource locators 
(URLs) are encoded into the video as described above. Again, the URLs are 
preferably encoded onto eight fields of line 21 of the VBI, but may also be sent 
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independently of the video. In this embodiment, a URL decoder 24 is located at 
the server site rather than at the subscriber location. When the decoder 24 
receives the video program signal, it strips out the URL codes on line 21 of the 
VBI and delivers these codes independently to an Internet server 28. The URL 
5 code is then subsequently delivered over the Internet 20 to the user PC 16. 
Simultaneously, the video is broadcast over conventional broadcast or cable 
transmission means 36 to the user's personal computer 16. 

The alternative shown in Figure 4, does not use the VBI. In this 
10 embodiment, the system runs an online service over the Internet 20. This 

service is in the form of an Internet web site 62 which provides a user-interface to 
a database 78 and to one or more associated data servers 90. The service 
provides member accounts to TV broadcasters 66 who sign up to use the 
illustrated system in conjunction with their broadcasts. Each member 
1 5 broadcaster will enter the service at their computer 70 through web browser 
software 74 using their member account by entering various identification and 
password information. Once within their account, the member will be provided 
with a graphical user interface for pre-scheduling URLs for transmission to users 
118 over a direct Internet connection 94 at particular times of day. The same 
20 user interface, or a variation of it, can be used by broadcasters for live 
transmission 82 of URLs to users at the same time as a broadcast 86. 

One example of this interface might be a scheduling calendar (daily, 
weekly, monthly, yearly) in which the broadcaster 66 may allocate time periods 

25 which coincide with their broadcasts 86, and during which they will send out 
URLs to their users to link to web pages. For each time period (for example, a 
particular hour long period during the day) determined by the broadcaster 66 to 
be a broadcast period (a period during which they want to transmit URLs that 
correspond to a television show being broadcast from their TV broadcast facility 

30 1 1 0 to the external TV 1 14 of the user 1 1 8 at that time), the broadcaster 66 may 
then enter a series of URLs into an associated file ("Link File") for transmission 
over the Internet 20 at that time. This Link File may have a user interface such 
as a spreadsheet, table, or list, or it may be simply a tab-delimited or paragraph- 
delimited text-file. As an example, each of the records in the Link File consists of 

35 a data structure which may contain information such as: 

(<timecode>,<URL> <label ortitle>, additional information>,<additional 
information^...) 
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The above data structure is just one example. The records in the Link File 
preferably specify the time, Internet address (i.e. URL), label (such as an 
associated name), and some optional additional information, for each web page 
5 the broadcaster 66 desires to launch during a show. 

When a broadcaster 66 modifies their calendar and/or the Link File 
associated with any given time period(s) in their calendar, this information is 
saved into the database 78 which is attached to the site 62. Each broadcaster 
10 66 may maintain multiple calendars in the database 78 if they broadcast in 
different time zones, for example. 

The database 78 provides the Link File records for upcoming time periods 
to a server 90, which may be one server or a distributed network of server 
1 5 programs on multiple computers across the network, to be utilized for scaling to 
large national or global audiences. The server 90 provides the Link File records, 
including the URLs, to the user's personal computer 16, which is connected via a 
network. Examples of possible networks include the public Internet 94, a direct 
private network, or even a wireless network. 

20 

One feature of the embodiment illustrated in Figure 4 is that one or more 
broadcasters 66 may utilize the same schedule in the database 78 for their own 
broadcasts 86 or during the same broadcast. For example, a network 
broadcaster may develop a master schedule and various affiliate broadcasters 

25 may subscribe to that schedule or copy it (in the database) and add or delete 
specific URLs in the schedule for their local audiences or unique programming. 
This scheme enables affiliates to insert URLs for local advertisers or local 
subjects into a sequence of more general URLs provided by their network 
broadcaster 66. In other words, the affiliate can add links that ride on the 

30 network feed and then redistribute it to their local audiences. 

The system of Figure 4 also enables personalization in the form of unique 
series of URLs specific to each user's unique profile, which are directly sent over 
the Internet 20 to each user's specific client software 106. This can be achieved 
35 from the broadcaster 66 to each individual user 1 18, or to particular collections of 
users. To accomplish personalization, the service may send a different stream of 
URLs to each user's client software program 106. The stream of URLs sent 
depends upon a user profile stored in the database 78 or the client software 
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program 106, a user profile which is built on demand or over time for each user 
118 based on criteria such as the location of the user, choices the user makes 
while using a client software program 106, choices the broadcaster 66 makes 
during a broadcast 86, or automatic choices made by an algorithm (such as a 
5 filter) residing on the service 62. Personalization enables each user to receive 
URLs which are uniquely relevant to their interests, demographics, history, or 
behaviour in the system. 

Once the URLs have reached the personal computer 16, the operation of 
1 0 all of the systems shown in Figures 1 , 2 and 4 is similar. 

In one embodiment, a JAVA enabled browser 98 as well as specialized 
software 106 are installed on the computer 16. The JAVA enabled browser 98 
allows the computer 16 to retrieve the web pages 102 and is presently the 

1 5 preferred software, as it is platform independent, and thus, enables efficient and 
flexible transfer of programs, images, etc., over the Internet 20. The specialized 
interface software 106 (hereinafter, "client software") acts as an interface 
between the video programming and the Internet functions. The client software 
1 06 retrieves URLs from the video program (embodiment of Figure 1) or directly 

20 from the Internet connection (embodiments of Figures 2 and 4), interprets these 
URLs and directs the JAVA enabled browser 98 to retrieve the particular relevant 
web pages 102. The client software 106 also synchronizes web pages to the 
video content for display on the user's computer 16, as shown in Figures 3 and 4 
and explained in more detail below. 

25 

As explained above, the URLs may be encoded and embedded into the 
video signal by inserting them into the vertical blanking interval (VBI). 

Alternatively, the URLs may be entered by member TV broadcasters 66 
30 along with specified times for transmitting the URLs to the user. At the 

appropriate times, the URLs are sent directly over the Internet to the user's PC 
16 via the client software 106 over a direct point-to-point or multicasting 
connection. 

35 The system may have the capability to detect identical URLs sent directly 

after one another and to cause the browser not to fetch URLs in these particular 
cases. As shown in Figure 3, once the URL code is received at the computer, 
the client software 106 first interprets the URL and determines in step 42 whether 



1 
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the particular URL has been received previously. If it has already been received, 
the next received URL is interpreted for determination of prior receipt. If the 
particular URL has not been detected before, the software checks for misspelling 
in step 46 and any other errors, and if errors exist, corrects these particular 
5 errors. Once again, it is determined whether the URL has been previously 

detected. If it has, the next URL is accessed in step 38. If the URL has not been 
detected, the specific URL is added to the URL list in step 54. The specific URL 
is then sent to the web browser, preferably a JAVA enabled browser 98. Upon 
receipt of the URL, the browser 98, in step 58, will access the web site address 
10 1 22 (Figure 4) indicated by the URL and retrieve the cited web page(s) 102 via 
the Internet. 

Viewers can view the integrated presentation in the following manner. As 
mentioned above, the video signal is processed and displayed on a video 
1 5 window on the PC screen using a WinTV card, for example. The corresponding 
audio is forwarded to the audio card and sent to the PC speakers. 

The retrieved web pages 102, referenced by the URL, are optionally time 
stamped to be displayed on the computer screen when predetermined related 

20 video content is displayed in the video window, thus enhancing the video 
presentation by providing in-depth information related to the video content 
thereto. Another section on the screen is also preferably used to represent an 
operational control panel. This control panel provides a list of the URLs which 
have been broadcast and correspondingly received by the computer 16. This 

25 control panel is updated to add a URL code each time a new URL code is 

received by the PC 16. This list gives the subscriber the flexibility to go back and 
retrieve particularly informative or interesting web pages that have already been 
displayed earlier in the program, or alternatively, to print them out for future 
reference. Furthermore, the list may include URLs referring to web pages not 

30 displayed with the broadcast program, but which provide further information on a 
certain topic of interest to the viewer. 

In an example, a viewer may begin watching a musical video featuring a 
band. As the video is received by the PC 16, URLs are either being received 
35 with the video signal or are being received directly via the Internet 20 or another 
data channel, and are interpreted by the client software 106. Upon direction and 
command, the JAVA enabled browser 98 retrieves particular web pages 102 
from Internet 20 web sites identified in the URLs. These web pages 102 are then 



displayed on the video screen at particular times. So, for example, whilst the 
viewer is watching the music video, biographical information on the band may 
also be displayed adjacent to the video window. Web pages 102 may also 
include an upcoming concert schedule, and/or audio clips of the band's music 
5 may be downloaded from the Internet 20. 

As another example, a user may be watching a program relating to 
financial news. Whilst the narrator is shown discussing high tech stocks, web 
pages corresponding to detailed financial performance information on high tech 

1 0 stocks, environment and characteristics may be displayed with the video on the 
computer screen. If the personalization features are included, web pages 
associated with a particular user's stock may be fetched and displayed on the 
computer screen with the video program. When the program narrator switches to 
a discussion on the weekly performance of the Dow Jones, web pages 

1 5 presenting related financial performance information may be simultaneously 
displayed. 

A user may view the interactive program using a television set 114 or 
other display monitor in conjunction with the display screen of the personal 

20 computer 16. In this case, the relevant web pages are shown on the personal 
computer 16 whilst the video program is displayed on the television monitor 1 14. 
In this alternative, a cable set top box receives the television program from the 
multi-channel cable. The personal computer 16 also receives the video program 
from the multi-channel cable and extracts the URLs, embedded in the vertical 

25 blanking interval of the video signal or directly transmitted 94 over the Internet 
20. The client software 106 extracts the URLs and retrieves the particular web 
pages as described above. The web pages are then synchronized with the 
particular video frames and presented to the user. It is understood that a 
hyperlink may exist on the web site that will allow the user to automatically load 

30 the client software and call up the specific television channel referenced in the 
web site. For example, someone browsing the Internet 20 may come upon a 
major television network's web site. It is possible then to scroll to an interesting 
story and then to click on an hyperlink to turn on the software which tunes the TV 
window to the network. 



Instead of receiving the video program from a transmission means, the 
video program may be addressed directly from the user site if the video program, 
with or without embedded URLs, has been stored on appropriate means. The 
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storage means may be a videotape in any format, such as VHS or Beta, or an 
optical disc in any format, such as DVD or CD-ROM. In this case, the user PC 
16 and/or television 114 are connected to a video tape player, a disc drive, or 
other appropriate device. 

5 

Figures 5 and 6 show two alternative examples of systems which may be 
employed. As shown in Figure 5, a user may view an interactive program using 
a television set 18 or other display monitor in conjunction with a digital cable box 
140. In this case, the digital cable box 140 performs the functions of the personal 
10 computer 16 shown in Figures 1 , 2 and 4, and the client software is stored in 
memory in the digital cable box 140. In one embodiment, the digital cable box 
140 includes two tuners, thus allowing both the web page and the video program 
to be simultaneously viewed on the same screen. If video and web stream, 
however, are carried on one channel, then only one tuner is necessary. 

15 

The client software retrieves URLs from the received video program, 
directly from the Internet connection 20 or via a separate data channel, interprets 
these URLs and directs the web enabled browser to retrieve the particular 
relevant web pages, and synchronizes the retrieved web pages to the video 
20 content for display on the television 18. The relevant web pages are preferably 
shown in one frame of the television 18 while the video program is displayed in 
another frame. Alternatively, the web page can replace the video program on the 
display. 



25 In this embodiment, the digital cable set top box 140 receives the 

television program from the multi-channel cable. The URLs can be encoded into 
the digital program channel using MPEG1, MPEG2, MPEG4, MPEG7 or any 
other compression video scheme. Alternatively, the URLs can be transmitted to 
the digital cable boxes 140 from an Internet server 148. The digital cable box 

30 140 decodes the URLs from the digital video signal or directly transmitted over 
the Internet 20. The client software decodes the URLs and retrieves the 
particular web pages as described above. Preferably, the web pages are 
synchronized with the particular video frames and presented to the user. 

35 As with all the embodiments described above, instead of receiving the 

video program from a transmission means, the video program may be addressed 
directly from a local video source 144 if the video program, with or without 
embedded URLs, is stored on a storage means such as a video tape or optical 
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disc. In this embodiment, the digital cable box 140 is connected to a VCR, disc 
drive or other appropriate device. 

Figure 6 illustrates an embodiment where a digital TV 152 is the remote 
5 reception unit and performs the functions of the personal computer, shown in 
Figures 1 , 2 and 4, and the digital cable box 140 shown in Figure 5. A processor 
means and memory are incorporated in the digital TV 152, and the client 
software and web browser software are implemented in memory in the digital TV 
1 52. All of the functions described above with reference to the other 
1 0 embodiments are performed in a similar manner by the digital TV 1 52 
embodiment. 

Although the digital cable box/TV 140, 18 and digital TV 152, shown in 
Figures 5 and 6, are incorporated into the embodiment of Figure 1, in substitution 
1 5 for the PC 1 6, they may also be substituted for the PC 16 shown in Figures 2 and 
4. 

A user may view the video and web content on one screen (in two 
windows), or with the video on one display screen and the web content on a 
20 separate display monitor. Alternatively, a user may access the video or web 

content separately. Thus, a user may branch from video to web content and vice 
versa. 

The systems described herein are well-suited to the education 
25 environment. Thus, students and teachers may access one or more web 

servers. Software components including instructor and student user software, 
authoring software and database assessment software are provided. An 
instructor may, for example, use content creation software on a personal 
computer to easily integrate into the curriculum current information published on 
30 the web through an interface 1 56 shown in Figure 7. The instructor creates a 
playlist (i.e. linkfile) 160, the playlist 160 comprising a list of web pages, text 
notes and questions. The web sites and questions are set out in a 
predetermined order and can be assigned times. Preferably, the URLs 
identifying the web site and time stamps are sent automatically to the desktop of 
35 each student in the virtual community, either during a playback of a pre-recorded 
program or during a live event. 
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At each of the student workstations, the program is directed by the playlist 
160. In other words, the playlist 160 provides the structure for the program. At 
predetermined times as indicated by the playlist 160, the browser will fetch and 
display a web page in a frame on the computer screen. Because program 
5 events can be set up in this manner at predetermined times, the entire program 
and playlist can be prerecorded and stored in a web database for later access by 
students. 

It will be appreciated that the students and the instructor may be located 
10 anywhere, as long as they are all connected to the web. Because a server 

controls the program, the instructor output comes from the server and the student 
workstations are automatically updated by the web server. 

This educational embodiment integrates web content and other media with 
15 collaborative groupware functionality to create an interactive environment for 
students and teachers. The student may receive a traditional video lesson 
through a frame in his or her web browser, or from a television. Separate frames 
may be simultaneously provided as shown in Figure 8, which shows the browser 
displaying: web pages 176 automatically delivered to each student's desktop with 
20 information or exercises that complement the video presentation; a chat dialogue 
frame 1 68 for conversing with the instructor and/or other students online; and an 
interactive playlist 164 of web pages and questions comprising the lesson. 

In the student interface of Figure 8, each student may perform a virtual 
25 experiment, for example, during a physics lesson to learn about gravity. In 
addition, the students may converse with one another and with the instructor 
using the chat dialogue frame 168. They may also send web pages to one 
another and provide answers to questions from the teacher via the chat dialogue 
frame 168 of the student interface 176. With the chat feature, students may 
30 break into subgroups for collaborative learning. Whenever a student in the group 
sends a message, the message is sent to the Internet server 20 and every other 
student in the subgroup receives and views the message in their chat dialogue 
frame 168. 

35 The instructor, however, may retain control over the chat feature. For 

example, the instructor may terminate the chat feature or web push to terminate 
unruly on-line conversations or the sending of web pages by students. 
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The systems described herein are more powerful than conventional 
distance learning systems as they allow the instructor to freely and conveniently 
exercise almost any type of testing strategy. The instructor may test students 
using a combination of the chat dialogue feature and web pages. For example, 
5 multiple choice questions and short answer questions can appear in the chat 
window 168. Essay questions, requiring longer answers, become web pages. 
As mentioned above, students can perform virtual experiments on-line. Once the 
instructor's personal computer receives student answers, student scoring may be 
presented to the instructor in any format including tables, charts, diagrams, bar 
1 0 graphs, etc. The instructor, thus, may analyze the results and has the capability 
of providing real-time feedback to the students. 

Students may also receive individualized feedback via branched 
interactive audio, video and/or graphics responses. For example, the workstation 

1 5 may branch to a particular audio response, preferably prerecorded in the 
instructor's own voice, based on the student response to a multiple-choice 
question. A plurality of potential audio responses may be made available at the 
student's workstation, for example, by a method as described in US patent No. 
5,537,141. Additionally and/or alternatively, personalized video, audio and 

20 graphics segments may be delivered and displayed to the student based on a 
student answer or personal profile, for example, in a manner as described in US 
patent No. 5,724,091. 

Responses to student answers may be more substantive using a memory 
25 feature comprising an algorithm which selects an interactive response to the user 
based not only on the student's current answer selection, but also on the 
student's previous responses. The algorithm, preferably stored in memory at 
each student s workstation and under processor control, selects an output 
interactive response based on student responses. In an example, a student who 
30 gets three or more answers in sequence right receives a more difficult question. 
However, a student who fails to correctly answer one or more of the three 
questions receives an easier question. 

The system illustrated in Figure 9 is capable of servicing large numbers of 
35 users, for example, several schools. As shown, communications servers 180 
distribute and route message across a LAN, WAN and the Internet. At the heart 
of the system is a group database server 1 84, and this is surrounded by several 
communication servers 180 which each serve an area 192. Each communication 
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server 180 is surrounded by squares representing user stations 188. The 
communication servers 180 are organized in node relationships with one 
another. 

5 Each node is responsible for serving an area 192. An area 192 is defined 

as a virtual location serviced by a single communication server 180 (or "com 
server"). An area 192 may be a single school, an office, or may consist of 
several actual physical locations. The defining characteristic of an area 192 is 
that messages sent from one member of an area 192 to another need not be 
1 0 routed outside of the servicing com server 1 80. 

An area member is analogous to the frequently used term "user*. For 
example, a "user" may be a student in an educational environment. 

15 The distributed communication system shown in Figure 9 permits the 

dynamic addition of communication servers 180 within a group with little or no 
administrative tasks as well as the addition of groups within an overall 
communications network. A communication server group consists of several 
defined virtual areas 192 (preferably, consisting of no more than 250 members 

20 each), each area 192 serviced by a single com server 1 80. This system allows 
members of one area 192, or group, to easily communicate with members of 
another area 192 or group without any configuration changes. 

In the past, service of very large numbers of users has required large 
25 expensive servers and networks. Furthermore, as the user base increased, 
performance suffered and the hardware had to be upgraded to service the 
demand. 

The distributed communication system allows the same, relatively 
30 inexpensive, machines to serve an ever-increasing user base. This is 

accomplished by routing messages from one server to another when necessary 
following substantially the same core pattern as IP routing and DNS lookups. If a 
message is for a member not belonging to the current area 192 or group, the 
message is routed through the distributed communication system until its 
35 destination, or someone who knows the destination and can deliver the 

message, is found. The destination may be cached so subsequent messages for 
that member or group may be more efficiently delivered. 
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Referring to Figure 9, if a message is posted by member "A" and is 
intended only for the members of group 1 , the message never leaves the area 1 
com server. However, if the message is intended for members of area 1 and for 
members of area 2, the area 1 com server forwards the message to the group 
database server 184. The message is broadcast to the members of area 1 and 
tagged in the group database server 184 as belonging to area 2. The message 
is then routed to area 2 and broadcast to area 2 members. With this technique, 
any member may potentially send a message to any other member. If the area 
com server 180 does not recognize the destination, the message is forwarded up 
the line. Each com server 180 does not need to know about any other server 
180. Messages are routed until they delivered. If undeliverable, the original 
sender is notified. 

New areas 192 can be added on the fly. When a new com server 180 is 
added to the network, it registers itself with the database application. 
Henceforth, any message destined for the new area 192 may be routed properly 
without altering the other area servers 180. 

This method and system works for global messages or for user to user 
messages. Furthermore, new groups may also be dynamically added. Once 
added, each new group database server 184 registers itself with the existing 
database servers 184. This distribution of load permits nearly unlimited 
expansion with existing software and hardware. Each server manages a finite 
number of members, cumulatively serving a growing community. 

Users need not be informed as to the particular com server 180 they 
should connect to. Members are directed to a single URL. The selection of the 
server for user connection is determined by load balancing software. In this 
manner, the network may appear to be a global network of servers or simply a 
local classroom. 

The architecture described, which uses database servers as routing 
gateways, enables the system to serve with minimum administration and 
configuration and with lower end, cost-effective hardware. 

A distributed community network provides services, including those 
discussed above, to an arbitrarily large community of end users by distributing 
the load among many machines, each providing specific parts of the community. 



- 17 - 



All server functions may reside on one machine in a modest context, whereas in 
a network of potentially millions, the web of distribution may involve additional 
server-side hardware or even actual client machines. An implementation of the 
distributed community network permits routing of content to be spread among 
5 multiple machines, which eases the processing burden on the server and 
provides for dynamic reconfiguration of the network. The dynamic 
reconfigurations may thus involve adding or removing machines to or from the 
network due to, for example, new network users or machine failures. As users 
and machines are added to the network, for example, those machines may 
10 include software packet switching. 

Examples of services maintained by the distributed community network 
include a chat service, whiteboard service, and content push/pull service. A chat 
service involves the ability of a particular group of users to interact such as via 

1 5 chat frame 168 shown in Figure 8. The interaction of a particular group of users 
is referred to as a room, and the distributed community network may dynamically 
change room assignments to add or delete users from a room. Users may be 
assigned to a particular room based upon their user profile. A whiteboard service 
involves the ability of users to receive frames of video information for network 

20 collaboration among the users. The whiteboard includes a frame of video 

information transmitted to users within the same network chat room. The users, 
depending upon their drawing privileges, may make modifications to the frame, 
and those modifications are transmitted to the other users. In this manner, the 
users may collaboratively draw upon the frame. 

25 

The term "push" refers to a configuration a shown in Figures 1 to 6 for 
automatic delivery of content to the user. The term "pull" refers to delivery of 
content requiring user interaction. A content push/pull service thus permits users 
to request content by, for example, selecting or "clicking on" an icon or URL in 
30 order to have content transmitted to their machine. In effect, the user "pulls" 
content to the user machine by requesting the content. The distributed 
community network may provide for other network-type services as well. 

Control over these individual services resides centrally on a server 
35 providing the services. However, packet distribution for that service may be 
distributed over many server or client machines implementing logical entities 
referred to as hubs. A hub is implemented in software, for example, and it 
performs routing of packets. The hubs need not implement the specific services 



- 18 - 



for which they distribute packets; rather, they typically need only know the routing 
protocol for the service. Similarly, centrally controlled routers maintain routing 
logic for implementing network services, and, for example, dynamically update 
algorithms for optimizing room assignments for a chat service without disturbing 
5 routing implemented by the hubs. 

In addition, rooms assignments for a chat service are organized 
hierarchically to facilitate distribution to a targeted audience. The chat service 
may be controlled by the client as in the case of a simple chat service. It may 

10 also be controlled by a database and content push/pull service making use of 
custom knowledge about a client via a profile for use in advertising purposes. In 
particular, the service may select advertisements to push to a particular client or 
user based upon the user's profile. Clients may also belong to multiple rooms in 
a chat service, making it simpler for a push/pull service to create distribution 

1 5 channels for similar clients by subscribing them to the new rooms. The push/pull 
service may then send the same or similar content to all members of the new 
room. 



Figure 10A shows an example of a physical network configuration for 
20 implementing a distributed community network 200. The configuration includes 
client machines 204,206,208 connected through a network 202 to a hub 220 
within a server 210. Network 202 may represent, for example, the Internet, a 
wide-area network, a local area network, or an intranet. Network 202 may also 
comprise a cable TV distribution medium, broadcast medium, satellite broadcast, 
25 telephone lines, fiber optics, or any other appropriate transmission medium. 
Each of the client machines includes access to particular services managed by 
corresponding servers. Client machine 204 provides donut, chat, and whiteboard 
services to a client or user at that machine, for example. Client machine 206 
provides donut and whiteboard services. Client machine 208 is a television. A 
30 client machine may also comprise a digital TV, a TV with a digital or analog cable 
box, or a computer connected with a TV. 

A donut service refers to the ability to provide content to users based upon 
user-profile information. The donut services specifies a "donut" of dynamic, 
35 hierarchical, shared user-profile information. In particular, it maintains either user 
profiles or database keys into a data repository containing the profiles. The 
donut may be stored in a file-type structure on a computer-readable medium 
such as a memory and accessed by browser programs, associated web server 
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programs, and other applications for use in routing content to the user associated 
with the donut 

Distributed community network 200 in this example includes three servers 
5 210,212 and 214. Server 210 includes hub 220 and a whiteboard service 216. 
Server 212 includes a hub 222 and a chat service 218. Server 214 includes a 
hub 224 connected to two exemplary services, a donut service 226 and a content 
push/pull service 228. Both services 226 and 228 are connected with a data 
repository 230. Examples of information for storage in data repository 230 
1 0 include user profiles, content for transmission to users, and web pages. 

Each of the three servers 210,212,214 are interconnected via their 
respective hubs 220,222, and 224. In addition, this embodiment includes an 
authoring client machine 232 connected with hub 224 in the server 214. The 
15 exemplary services 216,218,226, and 228 are only examples of services 

provided by servers. Many more services may also be provided by the server. 

For the sen/ices, the servers may provide many types of content such as, 
for example, video, audio, and multimedia. Web browsers for communicating 
20 with the server may be located in various places such as, for example, on a user 
machine, in a cable head end, in a satellite operations center, or in a set-top box. 
The web browsers may obtain the content in realtime, or it may be prefetched 
and cached either locally or on the server. In addition to web browsers, other 
entities may obtain content. 

25 

A distributed community network permits processing for these exemplary 
services to be distributed among multiple machines, such as servers 210,212, 
and 214. The routing for providing the services to client machines 204,206, and 
208 are distributed among the multiple hubs of the servers. Therefore, in order 
30 to transmit content to the client machines, the hubs in the servers provide route 
content from an authoring client machine 232 through network 202 to client 
machines 204, 206, and 208. 

Use of a distributed community network distributes processing among 
35 multiple machines in order to ease the burden of providing routing to multiple 
client machines. It also provides a dynamic reconfigurable network by shifting 
routing among multiple hubs so that additional client machines may be 
dynamically added to the network. Each of the client machines 204, 206, and 
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232 may be implemented with a conventional computer with communication 
capability for interacting through a network. Each of the servers 210, 212, and 
214 may be implemented with a typical server machine. 

Figure 10B shows the use of the network of Figure 10A for a particular 
application. For instance, during a professional football game, a user, Bob, first 
switches his cable set-top box to the appropriate video channel for the game. 
The video originates at a television operations center, is transmitted via satellite 
to a cable head end, then through a cable plant to Bob's set-top box. Bob also 
connects to the Internet 202 on his computer and accesses the matching 
HyperTV web page, involving a particular network service. This web page is 
located on a server in the point of presence for the service. The point of 
presence configures Bob's machine 204 into distributed community network 200. 
Machine 204 opens a persistent socket on configured hub A (220) and sends a 
subscribe message to configured chat service 218 via hub C (222). In response 
to the subscribe message, the chat service 218 sends an announcement packet 
to all the members of the configured room via hub A (220) and the Internet 202. 
In addition, the chat service 218 subscribes Bob to the appropriate push/pull 
service 228 via hubs C (222) and B (224). 

Push/pull service 228 extracts Bob's user profile donut from database 230 
and pushes the values of the profile down through hub B (224) and hub A (220) 
through the Internet 202 to Bob's machine 204. Since Bob's donut shows that he 
has previously indicated that he is a fan of the "Giants" football team, Bob is 
subscribed to a particular push room for Giant fans by push/pull service 228. As 
the game progresses, any pushed content for Giants fans and any chat 
messages from Bob's friends in the chat room are transmitted to him at machine 
204 as well. 

During the game, a content producer uses the authoring client 232 to send 
a web page detailing the biography of a Giants' player, the quarterback, and 
supporting links to hub B (224). The pushed information is routed to push/pull 
service 228, which sends a message to Bob and all the other members of that 
push room by routing it first to hub B (224). Hub B (224) in turn routes ft to hub A 
(220) which distributes it via Internet 202 to Bob's machine 204 and all his 
friends in the chat room. Hub B (224) might also have routed the message to 
other hubs that support other people in the same chat room. 
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Bob reviews the page on the Giants and decides he wants to play a 
prediction game about the quarterback's decisions from one of the displayed 
supporting links. Bob "clicks on" the link to select it and generate a pull request, 
which is transmitted through the persistent socket connection through the 
5 Internet 202. The request is routed via hub B (224) to push/pull service 228, 
which pulls the distributed object (a JAVA game) from database 230 and returns 
it via the same channel to Bob's machine 204. 

As the game progresses, Bob makes predictions about the quarterback's 
1 0 behaviour. After each play, data updating the game arrives from authoring client 
232 into hub B (224), and is then routed to QB game service 217 via hub A (220) 
and hub B (224). The game service processes the authoring client's data and 
sends the resultant data to Bob via hub A (220) and the Internet 202. The data is 
presented by the distributed object JAVA game on Bob's client machine 204. 

15 

The quarterback fumbles. The producer at authoring client 232 pushes a 
dynamic HyperText Markup Language (DHTML) instruction in Javascript through 
hub B (224) and hub A (220) through the Internet 202 to Bob's machine 204. At 
Bob's machine, the DHTML is executed and Bob receives on his computer 
20 screen an animated image of the word Fumble! 

Figure 1 1 A shows an example of a logic structure 240 for the distributed 
community network 200 shown in Figure 10A. Logic structure 240 illustrates 
logical relationships amongst entities within the physical distributed community 

25 network 200. In particular, an arrow represents a class/subclass relationship, 
and a diamond represents a relationship identifying an attribute of an entity. A 
client 244 may correspond with one of the client machines 204, 206, and 208 and 
it subscribes to a hub 248, which may correspond with hub 220, 222, or 224 
within one of the servers 210, 212, and 214. A server 246 may correspond with 

30 one of the servers 210, 212, and 214, and it manages a service 250, which may 
correspond with one of the services 216, 218, 226, or 228. 

Client 244 is a type of participant 243, which is a client machine 
subscribed to a particular service such a service 250. The client's status as 
35 participant 242 identifies it as a member of a particular room for a chat service. A 
directory 254 through a connection 252 provides communication for locating 
users for participant 242. In particular, connection 252 is a network connection 
between two participants over which packets can be sent, and directory 254 
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provides instructions for identifying which participants are to receive particular 
content, where they are located on the network, and which content they are to 
receive. 

5 Router 256 maintains map of a portion of the distributed community 

network for resolving routing questions from hubs, adding new participants to the 
network, and adding participants to services, which involves adding connections. 
In particular, hubs request routing decisions from router 256, and in response 
router 256 provides instructions to the hubs for their use in routing packets. For 
1 0 example, if hub A (220) failed, router 256 can issue instructions to the remaining 
hubs to avoid routing packets through hub A (220). 

Directory 254 includes information used in routing information among 
client machines, and it provides information to hub 248 for use in routing 

1 5 information. The term directory is used to refer to a room for a chat service or 
any other service. Directory 254 is a hierarchical collection of a directory, 
terminated with a room and it has a subdir (set of directories). A room is a 
directory and identifies a group of clients subscribed to a service, such as a chat 
sen/ice. A room has clients (set of participants) and hubs (set of hubs) where 

20 hubs is a subset of clients. 

Packet 258 is a structured piece of information delivered from one client to 
another. It may include any type of content for various services such as a 
push/pull service or a chat service. For example, in the chat service client 244 

25 creates a packet when the user enters information and sends it to a hub 
associated with the client's machine. The hub sends that packet to all the 
connections subscribed to that room. If the connections include another hub, the 
process iterates, thus distributing the packet to the room over multiple hubs. 
Packet 258 identifies hierarchical routing information including a source 

30 (participant), dir (directory), target (participant), conn (connection), and a route 
(set of participants). 

The packet with the routing information may include a variety of types of 
information as its payload or transmitted content. The packet may include data 
35 to be displayed, for example, to a user in a particular frame on a display device. 
The packet may also include one or more distributed executable objects, and the 
objects may include data, executable code, or data in combination with 
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executable code. The executable code may include, for example, a JAVA applet 
or any type of entity specifying executable code. 

Hub 248 includes software for routing packets, and it may be used to push 
5 an application or content to multiple users. Examples of such applications or 
content include a whiteboard, a JAVA game, chat messages, text, and a file. By 
distributing hubs among multiple machines, the burden on a server of routing 
packets is decreased. Also, hub 248 includes a connection to a router 256 for 
obtaining routing information, if necessary. Table 1 includes an example of hub 
10 logic for use by hub 248 in routing packet 258; this logic may be implemented in 
software or firmware modules for execution by a corresponding machine. 
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Table 1: Hub Logic 

receive Packet p 

// find my Directory dir 
if ! p.dir in my dirs 

my dirs[p.dir] = my routers.get(p.dir) 
d = my dirs[p.dir] 

// handle targeted and broadcast separately 
if p.target is empty 

// send it to all the clients in the room 
for i in d. clients (recursive) 
if i.conn != p.conn 
send p to i.conn 

else 

// see if I have a direct connection to the target 
for i in d. clients (recursive) 
if i.id==p.target 

send p to i.conn 

done // it's delivered 

// we don't have the client, so send it to 
// all the relevant hubs 
for i in d.hubs (recursive) 

// if it has routing info, route 
if i.id in p.route 

send p to i.conn 

done // it's en-route 

// otherwise, send it to all my sub-hubs 
else if p.route is empty 
send p to i.conn 

// we have to keep going, since it 
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// may not p.target may not be in i 

if we got this far, we failed to deliver 

send <not found> to p.source via p.connection 

5 

Figure 1 1B is an exemplary diagram of a physical network configuration 
259 for a distributed community network illustrating an alternative source for a 
video signal. Configuration 259 illustrates the distribution of video or television 

10 content using cable television signals. An operations center 261 generates a 
cable television signal having content for distribution and transmits the cable 
television signal over a satellite link 263 to one or more cable head ends 265. 
Cable head end 265 may include a web browser for interacting with a network 
such as the Internet 202. Cable head end 265 receives the cable television 

15 signal from satellite link 263 and distributes the signal over cable lines to client 
machines 267. Alternatively, the operations center may transmit over a satellite 
link to the client machines, foregoing the cable route. Client machines 267 may 
represent televisions or any machines capable of displaying cable television 
signals (such as a personal computer with a TV card or a module for processing 

20 TV signals for display). The client machines 267 may also include connection to 
a network such as the Internet 202 for implementing a distributed community 
network. 



Figure 12A shows an example of content push packet flow 260 in a 
25 distributed community network 200 for implementing a content push/pull service. 
The content push packet flow involves transmission of content via packets 
through the logic structure 240 shown in Figure 1 1 A as implemented in the 
physical distributed community network configuration 200 shown in Figures 10A 
and 10B. As described above, a system may provide to a user both video and 
30 other media content, such as any content available via a URl or a client-side 
script such as a JAVA script. The type of media content pushed to a user may 
depend upon the user's profile. 

The media content may include, for example, video, audio, combined 
35 video and audio, or multimedia content. When transmitting different types of 
media content, such as both video and audio, the media content may be 
transmitted from the same or different sources. In addition, the content may be 
transmitted from a wide variety of sources such as, for example, television, 
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broadcast television, cable, satellite, local video, and local CD-ROM or digital 
versatile disk (DVD). The local content may be stored on the hard disk drive of a 
user's machine. 

As shown in Figure 12A, a content push/pull packet flow 260 includes 
interaction of multiple machines transmitting the packets. The packets may 
originate from various sources such as a web browser on a client machine, a 
cable head end, or a server. Client machines 284, 276, and 268 may correspond 
with client machines shown in Figure 10A and client logic elements shown in 
Figure 1 1 A. Client 284 includes a browser program which provides frames for 
the following services: media 286, chat 290, and content 288. Client 276 likewise 
includes a browser program providing frames for media 280, chat 282, and 
content 278 services. Client 268 includes frames for media 270, chat 272, and 
content 274 services. Client 284, 276, and 268, as shown, typically have the 
same services or access to the same services; alternatively, they may each 
implement different services. Also, they may implement different network 
services than those shown, such as a whiteboard service as identified above. 

As shown in Figure 8, a chat service may include an associated chat 
frame 168 on a user's machine; content may include web pages 176; and media 
frames may include transmitted video programs. Also, as explained in the 
embodiments described above, the implementation of a chat service may use a 
digital television, digital cable box, or personal computer. In addition, the 
program from the program sources, such as those identified above, and the 
content from a network service, such as a chat service or a push/pull service, 
may be provided on the same or different physical machines. For example, both 
the program and the content may be provided on a television or on a personal 
computer, or they may be provided on separate physical machines such as 
providing the program on a television and providing the content for the network 
service on an associated personal computer. 

As shown in Figure 12A for the push/pull service flow, authoring client 262 
includes an authoring application 264 for creating a packet 266. An authoring 
application includes any program for use in creating a packet containing or 
identifying particular content. A server 292 provides for routing of packet 266. In 
particular, it includes a hub 294 coupled to a content push/pull service 296 and a 
chat service 298. The routing of packets and their content for the exemplary 



- 27 - 



content push/pull service is further explained in Table 2 illustrating packet 
structure throughout the flow. 

Authoring client 262, using authoring application 264, creates packet P-0 
5 (step 266) and transmits it to server 292 where it is received by hub 294 as 
packet P-1 (step 306). Hub 294 routes the packet to an individual target. In 
particular, content push/pull service 296 sends packet P-2 to an entire directory 
via hub 294 (step 308). Hub 294 routes packet P-3 to all members of the 
directory (step 306), and each client receives the packet P-4 (steps 
10 312,314,316). Hub 294 may include software for routing packets, as illustrated 
by the logic in Table 1 . The packets identify information in the header used by 
the hub logic in routing the packets for the push/pull service. 

Figure 12B shows an example of a push/pull packet content 271 for use in 
15 a distributed community network 260 as packet P-4. Packet 271 includes a 
primary URI 273 for use by client machines 262, 268, 276, and 284 in retrieving 
content to be pushed to the machines. Packet 271 may also include one or more 
URIs for use by the client machines in pulling content. For example, packet 271 
includes a URI 275 for a first pull item, a URI 277 for a second pull item, and a 
20 URI 279 for a third pull item. The pull items may include an element to be 
displayed to the user, such as an icon, such that when the user "clicks on" or 
selects the item, the corresponding client machine uses the URI associated with 
the displayed item to retrieve content and display the content to the user. Packet 
271 may include multiple URIs for pushed content, as well as the multiple URIs 
25 for pulled content. 
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Figure 13 shows an example of the chat packet flow 330 in a distributed 
5 community network 200. This diagram includes the same logic elements as are 
shown in Figure 12A with routing for flow of a chat packet using a chat service 
298 and implementations include the various alternatives identified above with 
respect to Figure 12A. 

1 0 The routing of packets and their content for the exemplary chat service is 

further explained in Table 3 illustrating packet structure throughout the flow. In 
this example, client 284 creates a new chat message as packet P-0 (step 332). 
The client may use an application associated with the chat service to enter 
information, such as typing in a text string using a keyboard, and send it in 

1 5 packet form. The application may include, for example, scripts associated with 
the chat frame on the user machine. 

Packet P-0 from client machine 284 is directed to the server 292 where it 
is received as packet P-1 (step 334). Hub 294 routes the packet to an individual 
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target as identified in the header information of the packet. In particular, chat 
service 298, using hub 294, sends packet P-2 to the entire directory (step 336). 
Hub 294 routes packet P-3 to all members of the directory (step 338), in which 
case is received by each of the client machines in the directory as packet P-4 
5 (steps 340, 342, 344). Hub 294 may include software for routing packets, as 
illustrated by the logic in Table 1 . 

Programs in each client machine 268, 276, 284 associated with the chat 
service, such as scripts associated with the chat frames in the client machine, 
10 receive packet P-4 and perform necessary processing to extract the content 
originally created by the user at machine 284 (packet P-0) and display that 
content in the chat frames 272, 282, 290. 



Table 3 





P-0 


P-1 


P-2 


P-3 


P-4 


source 


3000 


3000 


3000 


3000 


3000 


service 


chat 


chat 


chat 


chat 


chat 


target 


201 


201 








dir 


5 


5 


5 


5 


5 


Action 


SAY 


SAY 


SAY 


SAY 


SAY 


note 


client at 


hub 294 


chat 


hub 294 


each client 




machine 


routes 


service 298 


routes 


268, 276, 




284 enters 


packet P-1 


sends 


packet P-3 


284 in the 




new chat 


to 


packet P-2 


to all 


directory 




message, 


individual 


to entire 


members 


receives 




packet P-0 


target, chat 


directory 


of the 


packet P-4 






service 298 


via hub 294 


directory 





15 

Figures 14A to 14D shows examples of implementations for distributed 
community network 200. Figure 14A is a diagram of a distributed community 
network 350 for a small eSchool. The network 350 includes, in this example, a 
server 352 providing service for all chat rooms and whiteboards and is coupled to 
20 client machines 354, 356, 358, and 360. Each client machine may therefore 
access chat room and whiteboard services as managed by the server. Server 
352 may include a hub having software for routing information, as illustrated by 
the logic in Table 1. Server 352 may also include a connection with a network 
such as the Internet 202. 



25 
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Figure 14B is a diagram of an exemplary implementation of a distributed 
community network 200 such as a large eSchool 362. Configuration 362 
includes a router 364 connecting servers 366 and 368. Each server manages a 
separate chat room and may exchange information through router 364. Two 
5 clients 370 and 372 are connected with a server 366 for the first chat room. Two 
additional clients 374 and 376 are connected with server 368 for the second chat 
room. Servers 366 and 368 may include hubs having software for routing 
information, as illustrated by the logic in Table 1. Servers 366 and 368 may 
include a connection with a network such as the Internet 202. 

10 

Figure 14C shows an implementation of a distributed community network 
200 as a simple configuration 378 providing video and other content. 
Configuration 378 includes a server 380 coupled to clients 382 t 384, 386, and 
388. Server 380 in this example includes two directories identified as teams 1 

15 and 2. One directory includes clients 382 and 384, and the other includes clients 
386 and 388. These directories identify rooms for participants of a chat sen/ice 
maintained by server 380. Server 380 also identifies the type of content to be 
transmitted to the clients in its directory by being pushed to the clients by a 
content push/pull service. In this example, a first advertisement is to be 

20 transmitted to clients 382 and 386, and a second advertisement is to be 
transmitted to clients 384 and 388. Therefore, server 380 via a directory 
structure may specifically identify the type of content to be transmitted to 
particular clients. Server 380 may include a hub having software for routing 
information, as illustrated by the logic in Table 1 . Server 380 may also include a 

25 connection with a network such as the Internet 202. 

Figure 14D shows an implementation of a distributed community network 
as a complex configuration 390 providing video and other content. Configuration 
390 includes a server 392 and a server 394 both connected with a server 396. 
30 Server 396 is connected with hubs 398 and 400. Hub 398 is connected with 

clients 402 and 404, and hub 400 is connected with clients 406 and 408. Servers 
392, 394, and 396 may include hubs having software for routing information, as 
illustrated by the logic in Table 1 . 

35 Configuration 390 also includes its own directory structure for the routing 

of information. Server 396 routes to team 1 or hub 398, and provides separate 
advertisements for hubs 398 and 400. The teams identify rooms for participants 
of a chat sen/ice, and the advertisements refer to particular content to be pushed 



- 31 - 



to users by a content push/pull service. The directory for server 394 includes a 
first advertisement to be transmitted to server 396 and a second advertisement to 
be transmitted to server 396. The directory for hub 398 includes a first team for 
clients 402 and 404, and hub 400 and server 396. It further includes the first 

5 advertisement to be transmitted to client 402, and a second advertisement to be 
transmitted to client 404. The directory for hub 400 includes a first team for 
clients 406 and 408 and hub 398. It also includes a first advertisement to be 
transmitted to client 406, and a second advertisement to be transmitted to client 
408. Servers 392, 394, and 396 may also include a connection with a network 

10 such as the Internet 202. 

It will be appreciated that modifications in, and variations of, the 
embodiments described above may be made within the scope of the present 
invention as defined by the appended claims. 

15 
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CLAIMS : 

1 A method for providing content to at least one user over a distributed 
community network, comprising: 

establishing communication between a service and a first server 

associated with a distributed community network; 

establishing communication between the first server and a user; and 

providing the content from the service to the user; 

wherein the service provides content for distribution to at least one user 
over a distributed community network. 

2. A method as claimed in Claim 1 , comprising: 
receiving content from the first server; and 

presenting the content to the user via a presentation device. 

3. A method as claimed in Claim 2, wherein the content includes a video 
signal and the presentation device further comprises at least one device selected 
from a group comprising: television, digital television, computer work station, 
video monitor, computer monitor, wireless device, set top box, personal 
computer, hand-held computer, and a picture-in-picture display device. 

4. A method as claimed in Claim 2 or Claim 3, wherein the content includes 
or comprises an audio signal and the presentation device further comprises an 
audio sound system. 

5. A method for providing content to a user via a distributed community 

network, comprising: 

obtaining content from a service, wherein the service is in communication 
with a hub on a distributed community network; and 

enabling the service to provide the content to a user by transmitting the 
content through the hub to the user. 



6. A method as claimed in Claim 5, further comprising: 
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receiving the content at the hub; and 

presenting the content on a presentation device, the presentation device 
being in communication with a hub on the distributed community network. 

5 7. A method as claimed in Claim 6, wherein the content includes a video 
signal and the presentation device further comprises at least one device selected 
from a group comprising: a television, digital television, video monitor, computer 
monitor, wireless device, set top box, personal computer, a hand-held computer, 
and a picture-in-picture television display. 

10 

8. A method as claimed in Claim 6 or Claim 7, wherein the content includes 
or comprises an audio signal and the presentation device further comprises an 
audio sound system 

15 9. A method as claimed in any preceding claim, further comprising providing 
additional information from the service to the user, wherein the additional 
information is used to support an interactive communication service between a 
plurality of users. 

20 10. A method as claimed in Claim 9, wherein the interactive communication 
service includes at least one service selected from a group comprising: a donut 
service, a chat service, a whiteboard service, and a content push/pull service. 

11. A method as claimed in any preceding claim, further comprising: 
25 providing at least one address to the user, wherein the address identifies a 

network location at which content associated with the address is provided by a 
service; 

selecting the address; and 

communicating the selection of the address to a hub; 
30 whereupon receiving the selection of the address, the hub establishes a 

connection with a second server identified by the address, retrieves the content 
from the second server, and provides the content to the user. 
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12. A method as claimed in Claim 1 1 , wherein the address further comprises 
a uniform resource identifier. 



13. A method as claimed in Claim 12, wherein the uniform resource identifier 
5 further comprises an identifier selected from a group comprising a uniform 

resource locator and a uniform resource name. 

14. A method as claimed in any preceding claim, wherein the distributed 
community network further comprises at least one network element selected from 

10 a group comprising: the Internet, an intranet, a private network, and a public 
network. 

15. A method as claimed in any preceding claim, wherein content is provided 
to the user via at least one device selected from a group comprising: a network 

15 hub, a server, a router, a set top box, a computer work station, a personal 

computer, a hand-held computer, a television, a digital television, and a wireless 
device, and a computer monitor. 

16. A method as claimed in any preceding claim, wherein the content 

20 comprises information in at least one form selected from a group comprising: a 
video signal, an audio signal, a combined audio and video signal, video stills, 
animations, text, graphics, multimedia, slow frame video, and a sequence of 
individual frames. 

25 17. A method as claimed in any preceding claim, wherein the content relates 
to at least one selected from a group comprising: an advertisement, a game 
show program, a motion picture program, a live program, an audio program, a 
music video program, a pre-recorded program, a sports program, and a news 
program. 

30 

18. A method as claimed in any preceding claim, wherein communication 
between the service and a first server and/or between the service and a first hub, 
is established via a transmission medium selected from a group comprising: the 
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Internet, an intranet, radio frequency broadcast, a wireless connection, satellite 
broadcast, cable, telephone circuit, fibre optics, a public network, and a private 
network. 

5 19. A method as claimed in any preceding claim, wherein communication to 
provide information to the user is established via a transmission medium selected 
from a group comprising: the Internet, an intranet, radio frequency broadcast, a 
wireless connection, satellite broadcast, cable, telephone circuit, fibre optics, a 
public network, and a private network. 

10 

20. A method as claimed in any preceding claim, wherein the service 
automatically pushes content to the user 

21 . A method as claimed in any preceding claim, wherein the service provides 
15 content to the user upon receiving a user request. 

22. A method as claimed in any preceding claim, wherein the step of providing 
content from the service to the user further comprises retrieving the content from 
a data storage device. 

20 

23. A method as claimed in Claim 22, wherein the data storage device further 
comprises a device selected from a group comprising: an optical disc, for 
example a digital versatile disc or a CD format; a storage device, for example, 
associated with a computer or a set top box; a magnetic storage device, RAM, 

25 ROM, an optical storage device, and a CD ROM. 

24. A method as claimed in any preceding claim, wherein the content includes 
a package which contains at least one incidence of hierarchical routing 
information selected from a group comprising: a source, a directory, a target, a 

30 connection, and a route. 

25. A method as claimed in Claim 24, further comprising: 
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determining from the packet a route from the service to the user, wherein 
the route specifies at least one hub, provided in a server on the distributed 
community network, through which the content is to be routed to the user; and 

accessing a router to determine the preferred communications links 
between the service and the user, wherein the router provides instructions to at 
least one hub for use in routing the packet. 

26. A method for providing content, the content being requested by a user, via 
a distributed community network, comprising: 

receiving a request from a user for content; 

obtaining the content by transmitting the request to a distributed 
community network, wherein the distributed community network comprises a 
plurality of hubs, each of the hubs being in communication with at least one other 
hub in the distributed community network in order to route the request to one of 
the hubs capable of providing the requested content; and 

providing the content to the user. 

27. A method as claimed in Claim 26, wherein the content includes additional 
information which is used to support an interactive communication service 
between a plurality of users. 

28. A method as claimed in Claim 27, wherein the interactive communication 
service further comprises at least one selected from a group comprising: a donut 
service, a chat service, a whiteboard service, and a content push/pull service. 

29. A method as claimed in Claim 27 or Claim 28, wherein the additional 
information includes a uniform resource identifier. 

30. A method as claimed in Claim 29, wherein the uniform resource identifier 
is one selected from a group comprising a uniform resource locator and a 
uniform resource name. 
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31 . A method as claimed in any of Claims 26 to 30, further comprising 
presenting the content to the user via a presentation system. 



32. A method as claimed in Claim 31 , wherein the content includes a video 
5 signal and the presentation system further comprises at least one device 
selected from a group comprising: television, digital television, computer 
workstation, computer monitor, video monitor, wireless device, set top box, 
personal computer, hand-held computer, and a picture-in-picture display device. 

10 33. A method as claimed in Claim 31 or Claim 32, wherein the content 

includes an audio signal and the presentation system comprises an audio sound 
system. 

34. A method as claimed in any of Claims 26 to 33, wherein the distributed 

1 5 community network further comprises at least one network element selected from 
a group comprising: the Internet, an intranet, a private network, and a public 
network. 

35. A method as claimed in any of Claims 26 to 34, wherein the content is 
20 provided to the user via at least one device selected from a group comprising: a 

network hub, a server, a router, a set top box, a computer workstation, a 
personal computer, a hand-held computer, a television, a digital television, a 
wireless device, and a computer monitor. 

25 36. A method as claimed in any of Claims 26 to 35, wherein the content 
further comprises information in at least one form selected from a group 
comprising: a video signal, an audio signal, a combined audio and video signal, 
video stills, animations, text, graphics, multimedia, slow frame video, and a 
sequence of individual frames. 

30 

37. A method as claimed in any of Claims 26 to 36, wherein the content 
relates to at least one selected from a group comprising: an advertisement, a 
game show program, a motion picture program, a live program, an audio 
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program, a music video program, a pre-recorded program, a sports program, and 
a news program. 

38. A method as claimed in any of Claims 26 to 37, wherein the distributed 

5 community network, in order to establish communications links between each of 
the hubs, utilises at least one transmission medium selected from a group 
comprising: the Internet, an intranet, radio frequency broadcast, a wireless 
connection, satellite broadcast, cable, telephone circuit, fibre optics, a public 
network, and a private network. 

10 

39. A method as claimed in any of Claims 26 to 38, wherein the content is 
provided to the user via the distributed community network by establishing a 
communications link between the distributed community network and the user, 
the communications link using a transmission medium selected from a group 

1 5 comprising: the Internet, an intranet, radio frequency broadcast, a wireless 
connection, satellite broadcast, cable, telephone circuit, fibre optics, a public 
network, and a private network. 

40. A method as claimed in any of Claims 26 to 39, further comprising 
20 automatically pushing additional content to the user, wherein the additional 

content is associated with a profile for the user. 

41 . A method as claimed in Claim 40, wherein the additional content is 
pushed to the user before the requested content is provided to the user. 

25 

42. A method as claimed in Claim 40, wherein the additional content is 
pushed to the user after the requested content is provided to the user. 

43. A method as claimed in Claim 40, wherein the additional content is 
30 pushed to the user concurrently with the requested content. 

44. A method for automatically providing content to a user connected to a 
distributed community network comprising: 
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obtaining a user profile for a user; and 

automatically pushing content from a service to the user via a distributed 
community network, wherein the content is targeted to the user based upon the 
user profile. 

5 . 

45. A method as claimed in Claim 44, wherein the user is connected to the 
distributed community network via at least one transmission medium selected 
from a group comprising: the Internet, intranet, radio frequency broadcast, 
wireless connection, satellite broadcast, cable, telephone circuit, fibre optics, 

10 public network, and a private network. 

46. A method as claimed in Claim 44 or Claim 45, wherein the user profile is 
provided in a data storage device accessible by at least one server connected to 
the distributed community network. 

15 

47. A method as claimed in Claim 46, wherein at least one packet is 
communicated over a connection between the data storage device and the 
service, wherein the at least one packet includes content information. 

20 48. A method as claimed in Claim 47, wherein the at least one packet further 
comprises hierarchical information identifying a source, a target, a server, and a 
room to provide with the content information. 

49. A method as claimed in any of Claims 44 to 48, wherein the content 
25 includes an address, the address identifying a location on the distributed 

community network at which additional content associated with the address is 
provided by a service, and wherein the method further comprises: 
automatically selecting the address; and 

communicating the selection of the address to a hub connected to the 

30 user; 

whereupon receiving the selection of the address, the hub routes the 
selection of the address to a server identified by the address and provides the 
additional content associated with the address to the user. 
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50. A method as claimed in Claim 49, wherein the address further comprises 
a uniform resource identifier. 

51 . A method as claimed in Claim 50, wherein the uniform resource identifier 
further comprises an identifier selected from a group comprising a uniform 
resource locator and a uniform resource name. 

52. A method as claimed in any of Claims 44 to 51 , wherein the content 
relates to at least one selected from a group comprising: an advertisement, a 
game show program, a motion picture program, a live program, an audio 
program, a music video program, a pre-recorded program, a sports program, and 
a news program. 

53. A method as claimed in any of Claims 44 to 52, wherein the user is 
connected to the service via at least one device selected from a group 
comprising: a digital television, a set-top box, a web browser, a server, a router, a 
computer workstation, a personal computer, a hand-held computer, and a 
wireless device. 

54. A method as claimed in any of Claims 44 to 53, wherein the content 
further comprises information in at least one form selected from a group 
comprising: a video signal, audio signal, combined audio and video signal, video 
stills, animation, text, graphics, multimedia, slow frame video, and a sequence of 
individual frames. 

55. A computer readable medium containing instructions for routing content 
between a service and a user via at least one hub on a distributed community 
network, by: 

receiving a packet from a service, wherein the packet includes hierarchical 
routing information and content information; 

determining a target for receiving the packet; and 



transmitting the packet to the target via at least one hub on a distributed 
community network. 



56 A computer readable medium as claimed in Claim 55, wherein the 
instructions comprise accessing a directory containing an instruction, the 
instruction associating a target with at least one hub, wherein the directory is 
utilised in determining by which hub to route the packet to the target. 

57. A computer readable medium as claimed in Claim 55 or Claim 56, wherein 
the target further comprises a client, wherein the client is a logical representation 
of at least one device on the distributed community network configured to receive 
content from the service. 

58. A computer readable medium as claimed in Claim 57, wherein the device 
further comprises at least one device selected from a group comprising: a server, 
a router, a hub, a computer workstation, a digital television, a set-top box, a 
personal computer, a hand-held computer, and a wireless device. 

59. A computer readable medium as claimed in Claim 57 or Claim 58, wherein 
the instructions further comprise: 

establishing a connection to a participant, wherein the participant identifies 
a client as a subscriber to the service, the connection facilitating the transfer of 
the packet between the service and the participant. 

60. A computer readable medium as claimed in Claim 59, wherein the 
connection is establishing utilising at least one communications medium selected 
from a group comprising: the Internet, an intranet, radio frequency broadcast, 
wireless connection, satellite broadcast, cable, telephone circuit, fibre optics, a 
public network, and a private network. 

61. A computer readable medium as claimed in any of Claims 55 to 60, wherein 
the service further comprises one selected from a group comprising: a donut 
service, a chat service, a whiteboard service, and a content push/pull service. 
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62. A computer readable medium as claimed in any of Claims 55 to 61 , 
wherein the content information further comprises information in at least one form 
selected from a group comprising: an advertisement, a game show program, a 

5 motion picture program, a live program, an audio program, a music video 
program, a pre-recorded program, a sports program, and a news program. 

63. A computer readable medium as claimed in any of Claims 55 to 62, 
wherein the instructions further comprise presenting the content information on a 

1 0 presentation device. 

64. A computer readable medium as claimed in Claim 63, wherein the content 
information includes information in a video form and the presentation device 
further comprises at least one device selected from a group comprising: a 

15 television, a digital television, a computer workstation, a computer monitor, a 
wireless device, a personal computer, a hand-held computer, and a picture-in- 
picture display device. 

65. A system for providing content to at least one user over a distributed 
20 community network, comprising: 

means for establishing a communications link between a service and a 
user, wherein the service provides content for distribution to at least one user 
over a distributed community network; and 

means for providing content to the user; 
25 wherein, upon connecting a user to the distributed community network, 

said means for establishing a communications link locates the content, 
establishes the communications link, and provides the content to the user via the 
distributed community network. 

30 66. A system as claimed in Claim 65, wherein the means for establishing a 
communications link between the service and the user via the distributed 
community network further comprises: 
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means for establishing a location for the service on the distributed 
community network; and 

means for establishing a location for the user on the distributed community 

network; 

5 wherein the communications link between the service and the user is 

facilitated by connecting the means for establishing a location for the service with 
the means for establishing a location for the user. 

67. A system as claimed in Claim 66, wherein the means for establishing a 
10 location for the service further comprises a server which includes a server hub, 
the server hub providing interconnection capabilities with at least one additional 
hub located on the distributed community network. 

68 A system as claimed in Claim 66, wherein the means for establishing a 
1 5 location for the user further comprises an assigned server which includes an 
assigned hub, the assigned hub providing interconnection capabilities with at 
least one additional hub located on the distributed community network. 

69. A system as claimed in any of Claims 65 to 68, wherein the content 
20 includes additional information used by the distributed community network to 

support interactive communication services between a plurality of users. 

70. A system as claimed in Claim 69, wherein the interactive communication 
services include at least one service selected from a group comprising: a donut 

25 service, a chat service, a whiteboard service, and a content push/pull service. 

71 . A system as claimed in any of Claims 65 to 70, wherein the content 
includes an address, the address identifying a location on the distributed 
community network at which additional information associated with the address is 

30 provided by the service. 

72. A system as claimed in Claim 71 , wherein the address further comprises a 
uniform resource identifier. 
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73. A system as claimed in any of Claims 65 to 72, wherein the distributed 
community network includes at least one network element selected from a group 
comprising: the Internet, intranet, private network, and a public network. 

5 

74. A system as claimed in any of Claims 65 to 73, wherein the means for 
providing the content to the user further comprises at least one device selected 
from a group comprising: a network hub, a server, a router, a set top box, a 
computer workstation, a personal computer, a hand-held computer, a television, 

10 a digital television, a wireless device, an audio presentation device, and a video 
presentation device. 

75. A system as claimed in any of Claims 65 to 74, wherein the content further 
comprises information in at least one form selected from a group comprising: 

1 5 video signal, audio signal, combined audio and video signal, video stills, 

animations, text, graphics, multimedia, slow frame video, and a sequence of 
individual frames. 

76. A system as claimed in any of Claims 65 to 75, wherein the content 
20 relates to at least one selected from a group comprising: an advertisement, a 

game show program, a motion picture program, a live program, an audio 
program, a music video program, a video program, a pre-recorded program, a 
sports program, and a news program. 

25 77. A system as claimed in any of Claims 65 to 76, wherein the means for 
providing the content to the user utilises a second communications link between 
the distributed community network and a user device, the second 
communications link using at least one transmission medium selected from a 
group comprising: the Internet, intranet, radio frequency broadcast, wireless 

30 connection, satellite broadcast, cable, telephone circuit, fibre optics, a public 
network, and a private network. 
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78. A system as claimed in any of Claims 65 to 77, wherein the means for 
providing content to the user further comprises at least one device selected from 
the group consisting of: a television, a digital television, a set top box, a computer 
workstation, a video presentation device, an audio presentation device, a 

5 personal computer, a hand-held computer, and a wireless device. 

79. A system for providing content to at least one user over a distributed 
community network, comprising: 

a service provider providing content for distribution to at least one user 
1 0 over a distributed community network; 

a client machine connected to the distributed community network; and 
at least one presentation device connected to the client machine; 

whereupon receiving an address identifying the service provider, the client 
machine establishes a connection with the service provider via the distributed 
1 5 community network, receives content from the service provider, and presents the 
content to the user via the at least one presentation device. 

80. A system as claimed in Claim 79, wherein the service provider provides at 
least one service selected from a group comprising: a donut service, a chat 

20 service, a whiteboard service, and a content push/pull service. 

81 . A system as claimed in Claim 79 or Claim 80, wherein the service provider 
is connected to the distributed community network via at least one hub, the hub 
providing interconnection capabilities with at least one additional hub located on 

25 the distributed community network. 

82. A system as claimed in any of Claims 79 to 81 , wherein the client machine 
is connected to the distributed community network via an assigned hub, the 
assigned hub providing interconnection capabilities with at least one additional 

30 hub located on the distributed community network. 

83. A system as claimed in Claim 82, wherein the communications link 
between the assigned hub and the client machine further comprises at least one 
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transmission medium selected from a group comprising: the Internet, intranet, 
radio frequency broadcast, wireless connection, satellite broadcast, cable, 
telephone circuit, fibre optics, a public network, and a private network. 

84. A system as claimed in any of Claims 79 to 83, wherein the client machine 
further comprises at least one device selected from a group comprising: a 
television, a digital television, a set top box, a computer workstation, a video 
presentation device, an audio presentation device, a personal computer, a hand- 
held computer, and a wireless device. 

85. A system as claimed in any of Claims 79 to 84, wherein the distributed 
community network includes at least one network element selected from a group 
comprising: the Internet, intranet, private network, and a public network. 

86. A system as claimed in any of Claims 79 to 85, wherein the content 
relates to at least one selected from a group comprising: an advertisement, a 
game show program, a motion picture program, a live program, an audio 
program, a music video program, a video program, a pre-recorded program, a 
sports program, and a news program. 

87. A distributed community network comprising: 

a client machine providing an interface through which a user may 

communicate a request and receive content; 

a network accessible to the client machine; 

at least one service provider connected to the network; and 

at least one server connected to the network, wherein the server further 

comprises a hub, the hub facilitating a connection between the service 

provider and the client machine; 

wherein content is communicated between the service provider and the 
client machine over the network. 



88. A distributed community network as claimed in Claim 87, wherein the 
client machine further comprises a device selected from a group comprising: 
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television, a digital television, a set top box, a computer workstation, a personal 
computer, a hand-held computer, and a wireless device. 

89. A distributed community network as claimed in Claim 87 or Claim 88, 

5 wherein the client machine further comprises a device capable of presenting to a 
user a signal in a form selected from a group comprising: a video signal, an audio 
signal, a multimedia signal, a combined audio and video signal, video stills, 
animations, text, graphics, slow frame video, and a sequence of individual 
frames. 

10 

90. A distribution community network as claimed in any of Claims 87 to 89, 
wherein the network further comprises a network selected from a group 
comprising: the Internet, intranet, private network, and a public network. 

15 91 . A distributed community network as claimed in any of Claims 87 to 90, 
wherein the network is accessed by the client machine utilising a 
communications medium selected from a group comprising: the Internet, intranet, 
private network, public network, radio frequency broadcast, wireless connection, 
satellite broadcast, cable, telephone circuit, and a fibre optics circuit. 

20 

92. A distributed community network as claimed in any of Claims 87 to 91 , 
wherein the at least one service provider provides at least one sen/ice selected 
from a group comprising: a donut service, a chat service, a whiteboard service, 
and a content push/pull service. 

25 

93. A distributed community network as claimed in Claim 92, wherein the 
donut service provides content to the user based upon a user profile. 

94. A distributed community network as claimed in any of Claims 87 to 93, 

30 wherein multiple services are provided to the user by utilising at least two service 
providers connected to the network. 
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95. A distributed community network as claimed in any of Claims 87 to 94, 
wherein the content is provided by the service provider to the client machine in a 
packet transmitted over the network, wherein the packet includes hierarchical 
information and content information. 

5 

96. A distributed community network as claimed in Claim 95, wherein the 
hierarchical information further comprises an identification of a source, a server, 
a room, and a target. 

10 97. A distributed community network as claimed in Claim 95 or Claim 96, 
wherein the hierarchical information directs a router, provided in a server, to 
obtain from a directory an identification of a hub associated with the client 
machine such that the content is communicated from the service provider to the 
client machine via the hub, the network, and at least one server associated with 

1 5 the service provider. 

98. A distributed community network as claimed in Claim 97, wherein the 
directory further comprises a data storage device connected to a server, the data 
storage device containing a listing of users subscribed to a service and a listing 

20 of hubs associated with the users. 

99. A distributed community network as claimed in any of Claims 87 to 98, 
wherein the content relates to at least one program selected from a group 
comprising: an advertisement, a game show program, a motion picture program, 

25 a live program, an audio program, a music video program, a pre-recorded 
program, a news program, and a sports program. 

1 00. A server for providing additional information over a distributed community 
network to a user, comprising: 

30 a service connected to a distributed community network; and 

a computing device having programming code enabling the computing 
device to act as a hub, on the distributed community network, for the service; 
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whereupon establishment of a communications link between the user the 
distributed community network, at least one packet is communicated from the 
service, via the computing device, to the user, the packet providing instructions 
for connecting the user to the service and containing content. 

5 

101 . A server as claimed in Claim 100, wherein the hub is in communication 
with at least one other hub on the distributed community network. 

102 A server as claimed in Claim 100 or Claim 101, wherein the service further 
10 comprises a service selected from a group comprising: a donut service, a chat 
service, a whiteboard service, and a content push/pull service. 

103. A server as claimed in any of Claims 100 to 102, wherein the service is 
provided over the distributed community network concurrently with a 

15 programming signal. 

1 04. A server as claimed in any of Claims 1 00 to 1 03, wherein the service 
provides a playlist, the playlist further comprising at least one uniform resource 
identifier identifying additional information, the additional information being 

20 provided by the computing device for presentation to the user concurrently with a 
programming signal. 

1 05. A server as claimed in Claim 1 04, wherein the at least one uniform 
resource identifier further comprises at least one of a group comprising: a 

25 uniform resource locator and a uniform resource name. 

1 06. A server as claimed in any of Claims 1 00 to 1 04, wherein the service 
provides content in a form selected from a group comprising: a video signal, 
audio signal, combined audio and video signal, text, graphics, animations, video 

30 stills, sequence of individual frames, multimedia, and slow frame video. 

1 07. A server as claimed in any of Claims 1 00 to 1 06, wherein the computing 
device is connected to the distributed community network utilising at least one 
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transmission medium selected from a group comprising: the Internet, intranet, 
private network, public network, radio frequency broadcast, wireless connection, 
satellite broadcast, cable, telephone circuit, and fibre optics. 

108. A server as claimed in any of Claims 100 to 107, wherein the content 
relates to at least one form of programming selected from a group comprising: an 
advertisement, a game show program, a motion picture program, a live program, 
an audio program, a music video program, a pre-recorded program, a sports 
program, and a news program. 

109. A method for providing content related to a program to a recipient over a 
distributed community network, comprising: 

providing content related to a program via a service provider connected to 
a distributed community network; 

associating the content with at least one uniform resource identifier 
identifying the service provider; and 

compiling a playlist, wherein the playlist includes at least one uniform 
resource identifier associated with the content; 

wherein upon a user establishing a communications link with the 
distributed community network, a connection is established with the user to the 
service provider identified by the uniform resource identifier such that the content 
is provided to the user. 

110. A method as claimed in Claim 109, wherein the distributed community 
network includes a plurality of hubs, wherein each hub is in communication with 
at least one other hub. 



111. A method as claimed in Claim 1 09 or Claim 1 10, wherein the playlist 
further comprises a plurality of uniform resource identifiers designed to be 
transmitted to a user concurrently with a program. 



112. A method as claimed in Claim 109 or Claim 1 10, wherein the playlist 
further comprises a plurality of uniform resource identifiers designed to be 
presented to a user after presentation of a program. 

113. A method as claimed in any of Claims 1 09 to 1 1 2, wherein the service 
provider provides a service selected from a group comprising: a donut service, a 
chat service, a whiteboard service, and a content push/pull service. 

114. A method as claimed in any of Claims 1 09 to 1 1 3, wherein the content is 
in a form selected from a group comprising: a video signal, audio signal, 
combined audio and video signal, text, graphics, animations, video stills, 
sequence of individual frames, multimedia, and slow frame video. 

115. A method as claimed in any of Claims 1 09 to 1 14 wherein the assigned 
hub is connected to the distributed community network utilising at least one 
transmission medium selected from a group comprising: the Internet, intranet, 
private network, public network, radio frequency broadcast, wireless connection, 
satellite broadcast, cable, telephone circuit, and fibre optics. 

116. A method as claimed in any of Claims 1 09 to 1 1 5, wherein the content 
relates to at least one form of programming selected from a group comprising: an 
advertisement, a game show program, a motion picture program, a live program, 
an audio program, a music video program, a pre-recorded program, a sports 
program, and a news program. 

117. A method for presenting additional information related to a program to a 
user via at least one presentation device, comprising: 

receiving a program; 

receiving additional information related to the program via a distributed 
community network, wherein the distributed community network comprises a 
plurality of hubs, each of the hubs being in communication with at least one other 
hub; 

transmitting the program to a first presentation device; and 
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transmitting the additional information to a second presentation device. 

118. A method as claimed in Claim 117, wherein the first presentation device is 
a television and the second presentation device is a computer monitor. 

119. A method as claimed in Claim 1 17, wherein a single presentation device 
functions as both the first presentation device and the second presentation 
device. 

1 20. A method as claimed in any of Claims 1 1 7 to 1 1 9, wherein the additional 
information is provided to the user over the distributed community network via at 
least one transmission medium selected from a group comprising: the Internet, 
intranet radio frequency broadcast, wireless connection, satellite broadcast, 
cable, telephone circuit, fibre optics, public network, and a private network. 

121. A method as claimed in any of Claims 1 1 7 to 120, wherein the additional 
information is pushed to the user based upon a user profile provided in a data 
storage device accessible by at least one hub on the distributed community 
network, and wherein the method further comprises: 

establishing a connection with a hub providing a user profile; 
associating a user profile with the user; and 

pushing additional information associated with an identified user profile to 
the second presentation device over the distributed community network. 

122. A method as claimed in any of Claims 117 to 121, wherein the additional 
information further comprises a uniform resource identifier. 

123. A method as claimed in Claim 122, wherein the uniform resource identifier 
further comprises an identifier selected from a group comprising: a uniform 
resource locator and a uniform resource name. 

1 24. A method as claimed in any of Claims 1 1 7 to 1 23, wherein the additional 
information relates to at least one selected from a group comprising: an 
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advertisement, a game show program, a motion picture program, a live program, 
an audio program, a music video program, a pre-recorded program, a sports 
program, and a news program. 

5 125. A method as claimed in any of Claims 117 to 124, wherein at least one of 
the first presentation device and the second presentation device comprises a 
device selected from a group comprising: a television, digital television, set-top 
box, web browser, a computer workstation, video monitor, computer monitor, 
sound reproduction system, personal computer, a hand-held computer, and a 
10 wireless device. 

126. A method as claimed in any of Claims 117 to 125, wherein the additional 
information further comprises information in at least one form selected from a 
group comprising: a video signal, audio signal, combined audio and video signal, 

15 video stills, animation, text, graphics, multimedia, slow frame video, and a 
sequence of individual frames. 

127. A system for receiving content provided by a service over a distributed 
community network comprising: 

20 a receiving means connected to an assigned hub on a distributed 

community network, and 

a presentation device, connected to the receiving means for presenting 
the content received from a service over the distributed community network; 

wherein the receiving means establishes a communications link with the 
25 assigned hub, transmits requests for content to the assigned hub, and receives 
content from the service via a second hub on the distributed community network. 

128. A system as claimed in Claim 127, wherein the content is transmitted in a 
packet, the packet containing hierarchical information and content information. 

30 

129. A system as claimed in Claim 128, wherein the hierarchical information 
further comprises an identification of a source, a server, a room, and a target, 
and wherein the hierarchical information directs a router on the distributed 
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community network to obtain from a directory an identification of a hub 
associated with the service such that content may be communicated from the 
service to the receiving means via the assigned hub. 

5 130. A system as claimed in any of Claims 127 to 129, wherein the content 
relates to at least one program selected from a group comprising: an 
advertisement, a game show program, a motion picture program, a live program, 
an audio program, a music video program, a pre-recorded program, a news 
program, and a sports program. 

10 

131. A system as claimed in any of Claims 127 to 130, wherein the receiving 
means comprises at least one device selected from a group comprising: a 
television, a digital television, a set-top box, a computer workstation, a personal 
computer, a hand-held computer, and a wireless device. 

15 

132. A system as claimed in any of Claims 127 to 130, wherein the 
presentation device comprises at least one device selected from a group 
comprising: a television, a digital television, a set-top box, an audio sound 
system, a radio, a computer workstation, a personal computer, a hand-held 

20 computer, and a wireless device. 

133. A system as claimed in any of Claims 127 to 132, wherein the system 
further comprises second receiving means for receiving a programming signal 
related to the content provided by the service. 

25 

134. A system as claimed in Claim 133, wherein the programming signal and 
the content are presented simultaneously in the presentation device. 

135. A system as claimed in Claim 133, wherein the system further comprises 
30 a second presentation device, and the programming signal is presented via the 

second presentation device. 
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1 36. A system as claimed in any of Claims 1 33 to 1 35, wherein the 
programming signal comprises at least one program in a form selected from a 
group comprising: a video signal, an audio signal, a multimedia signal, a 
combined audio and video signal, video stills, animations, text, graphics, slow 

5 frame video, and a sequence of individual frames. 

1 37. A system as claimed in any of Claims 1334 to 1 36, wherein the 
programming signal is provided via a data storage device selected from a group 
comprising: a digital versatile disk, a storage device provided with a computer 

10 workstation or set top box, a magnetic storage device, RAM, ROM, an optical 
storage device, and a CD ROM. 

1 38. A system as claimed in any of Claims 127 to 1 37, wherein the content 
includes information in at least one form selected from a group comprising: a 

15 video signal, an audio signal, a multimedia signal, a combined audio and video 
signal, video stills, animations, text, graphics, slow frame video, and a sequence 
of individual frames. 

1 39. A system as claimed in any of Claims 1 27 to 1 38, wherein the content is 
20 associated with a service selected from a group comprising: a donut service, a 

chat service, a whiteboard service, and a content push/pull service. 



1 40. A system as claimed in Claim 1 39, wherein the donut service provides 
content associated with a user profile. 
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